package 简单多状态问题;

/**
 * @Date 2024/10/7 11:30
 * @description: 两个数组dp: 按摩师
 * .        https://leetcode.cn/problems/the-masseuse-lcci/
 * @Author LittleNight
 */
public class likou16 {

    // 动态规划, 练习
    public int massage(int[] nums) {
        int n = nums.length;
        int[] f = new int[n]; // 选i位置
        int[] g = new int[n]; // 不选i位置

        // 初始化
        f[0] = nums[0]; g[0] = 0;
        for (int i = 1; i < n; i++) {
            f[i] = g[i - 1] + nums[i];
            g[i] = Math.max(g[i - 1], f[i - 1]);
        }
        return Math.max(f[n - 1], g[n - 1]);
    }

}
